<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>具名插槽</title>
</head>

<body>
    <template id="sub-component">
        <div>
            <header>
                <slot name="header"></slot>
            </header>
            <section>
                <!-- 不加name属性，等同于name="default" -->
                <slot></slot>
            </section>
            <footer>
                <slot name="footer"></slot>
            </footer>
        </div>
    </template>

    <main id="app">
        <h2>引入子组件1</h2>
        <!-- 内容默认会放入到，没有名字的插槽中（默认名插槽，default） -->
        <sub-component>
            <template v-slot:default>
                <p>我的名字：{{name}}</p>
            </template>
        </sub-component>
        <h2>引入子组件2</h2>
        <!-- 内容默认会放入到，没有名字的插槽中（默认名插槽，default） -->
        <sub-component>
            <template v-slot:header>
                <h3>我是头部</h3>
            </template>
            <template v-slot:default>
                <p>我的名字：{{name}}</p>
                <p>我的名字：{{name}}</p>
            </template>
            <template v-slot:footer>
                <p>我是尾部</p>
            </template>
        </sub-component>
        <!-- v-slot:可以简写成# -->
        <sub-component>
            <template #header>
                <h3>我是头部</h3>
            </template>
            <template #default>
                <p>我的名字：{{name}}</p>
                <p>我的名字：{{name}}</p>
            </template>
            <template #footer>
                <p>我是尾部</p>
            </template>
        </sub-component>
    </main>
</body>
<script src="../vue.js"></script>
<script>

    Vue.component("sub-component", {
        template: "#sub-component",
        data() {
            return {

            }
        }
    })

    new Vue({
        el: "#app",
        data() {
            return {
                name: "奉先",
                age: 35
            }
        }
    })
</script>

</html>